WHAT IS CLAIMED IS : 

1. A system for building a downlink portion of a data frame having a 
predetermined period, for use in a wireless communication system having a base station 
coupled to a network backhaul and a plurality, of Customer Premises Equipment's 

5 ("CPE"), each of said plurality of CPE's being coupled to a plurality of end user 

connections, and for transmitting^^ciata packets from the base station to specified 
CPE's, the system comprising: 

a first processor including a Media Access Controller ("MAC") 
configured to establish and maintain connections with said plurality of CPE's; 
1 0 a MAC Co-Processor ("MCP") having 

a Look-Up Table ("LUT") operable to retrieve and store CPE 
settings for said specific CPE, 
O a buffer operable to store data packets according to a sort criteria, 

(33 a decision module operable to determine if said buffer contains 

2^ 15 data to fill said downlink portion of said data frame or if said predetermined 

|]y period has occurred, 

H *4 said MCP is configured to output said data stored in said buffer 

i*3 when said decision module determines that said buffer contains data to fill said 

downlink portion of said data frame^ or^oaid predetermined period (nn^ow - h ae / 
W\ 20 occurred; and ^^wU^ \ t cr\ ^ 

u a modem coupled to receive said data outputted by said MCP. 

2. The system of Claim 1, wherein said data frame further comprises an uplink 
portion; 

said MAC is configured to determine a TDD split, wherein said TDD 
25 split is a division of said predetermined period between said uplink portion and said 

downlink portion. 

3. The system of Claim 2, wherein said downlink portion is transmitted on 
a first channel and said uplink portion is received on said first channel within said 
predetermined period. 

30 4. The system of Claim 1, wherein said data frame further comprises an uplink 

portion; 



said downlink portion is equal to said predetermined period, and said 
uplink portion is equal to said predetermined period. 

5. The system of Claim 4, wherein said downlink portion is transmitted on a 
first channel within said predetermined period and said uplink portion is received on a 
second channel within said predetermined period. 

6. The system of Claim 4, wherein said downlink portion is transmitted on a 
first channel within a first predetermined period and said uplink portion is received on a 
second channel within a second predetermined period, wherein said first predetermined 
period and said second predetermined period do not overlap. 

7. The system of Claim 4, wherein said system further comprises a Quality 
of Service module ("QoS") connected to said network backhaul and configured to 
receive a data packet associated with a specific CPE and to assign a priority level to said 
data packet. 

8. The system of Claim 1, wherein said predetermined period is five hundred 
microseconds. 

9. The system of Claim 1, wherein said predetermined period is one 
millisecond. 

10. The system of Claim 1, wherein said predetermined period is two 
milliseconds. 

11. The system of Claim 1, wherein said predetermined period is between 250 
microseconds and 20 milliseconds. 

12. The system of Claim 1, wherein said sort criteria is a modulation type. 

13. The system of Claim 1, wherein said sort criteria is a forward error 
correction type. 

14. The system of Claim 1, wherein said sort criteria is a CPE index, wherein 
said CPE index indicates the specific CPE to which said data packet is destined. 

15. The system of Claim 1, wherein each of said plurality of end user 
connections has a specific connection ID and said sort criteria is said specific 
connection ID. 

16. The system of Claim 1, wherein said decision module determines if said 
buffer contains data to fill said downlink portion of said data frame by iteratively 





# 



subtracting an amount of downlink bandwidth required by each of said received data 
packets, at each of said CPE's specific modulation type, from a total amount of 
downlink bandwidth available. 

17. The system of Claim 1, wherein said decision module determines if said 
buffer contains data to fill said downlink portion of said data frame by iteratively 
subtracting an amount of downlink bandwidth required by each of said received data 
packets, at each of said CPE's specific FEC type, from a total amount of downlink 
bandwidth available. 

18. The system of Claim 1, wherein said decision module determines if said 
buffer contains data to fill said downlink portion of said data frame by iteratively 
subtracting an amount of downlink bandwidth required by each of said received data 
packets, at each of said CPE's specific modulation and FEC type, from a total amount 
of downlink bandwidth available. 

19. The system of Claim 2, wherein during said uplink portion of said data 
frame, said MCP receives a plurality of uplink data packets and routes each of said 
plurality of uplink data packets to either the MAC or to the network backhaul. 

20. The system of Claim 4, wherein during said uplink portion of said data 
frame, said MCP receives a plurality of uplink data packets and routes each of said 
plurality of uplink data packets to either the MAC or to the network backhaul. 

21. The system of claim 1, wherein said MCP may perform any combination 
of packing, payload header compression, and fragmentation on said downlink portion of 
said data frame. 

22. The system of Claim 1, wherein said MCP adds control settings to said 
data stored in said buffer, wherein said control settings may include a modulation type, 
a FEC type, an encryption ON/OFF flag, an encryption key, a key number, and modem 
control information specific to each of said plurality of CPE's. 

23. The system of Claim 1, wherein said first processor further comprises: 



bandwidth according to uplink bandwidth requests from said plurality of CPE's. 

24. A system for building a TDD data frame with a plurality of data packets, 
said data frame having a predetermined period and comprising a downlink portion and 



an uplink bandwidth module configured to allocate available uplink 




an uplink portion, for use in a communication system having a base station and a 
plurality of Customer Premises Equipment's ("CPE"), each of said plurality of CPE's 
being coupled to a plurality of end user connections, the system comprising: 

a first processor configured to divide said predetermined period into said 
downlink portion and said uplink portion; 

a coprocessor including 

a buffer storage module configured to receive and sort said 
plurality of data packets in a buffer, 

a buffer update module configured to add control settings to said 
plurality of data packets in said buffer, 

an interface module configured to transmit said plurality of data 
packets in said buffer to an output, wherein said transmission occurs at the end 
of said predetermined period. 

25. The system of Claim 24, wherein said buffer storage module sorts said 
plurality of data packets in said buffer according to a burst type associated with each of 
said plurality of data packets, wherein a burst type is any combination of a modulation 
type and a FEC type. 

26. The system of Claim 24, wherein said coprocessor further comprises a 
routing module configured to route an uplink data packet to either the MAC or the 
network backhaul. 

27. The system of Claim 24, wherein said control settings may comprise a 
modulation type, a FEC type, an encryption ON/OFF flag, an encryption key, a key 
number, and modem control information specific to each of said plurality of CPE's. 

28. The system of Claim 24, wherein said predetermined period is five hundred 
microseconds* 

29. The system of Claim 24, wherein said predetermined period is one 
millisecond. 

30. The system of Claim 24, wherein said predetermined period is two 
milliseconds. 

31. The system of Claim 24, wherein said predetermined period is between 250 
microseconds and 20 milliseconds. 
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32. The system of Claim 24, wherein said interface module creates a download 
utilization message in response to an amount of bandwidth used in a previous data 
frame. 

33. The system of Claim 24, wherein said first processor further comprises: 

a downlink utilization message module configured to receive a downlink 
utilization message from said interface module, said downlink utilization message is 
usable by said first processor to determine said uplink portion and said downlink portion 
of said predetermined period. 

34. The system of Claim 24, wherein said first processor further comprises: 

an uplink bandwidth module configured to allocate available uplink 
bandwidth according to uplink bandwidth requests from said plurality of CPE's. 

35. The system of Claim 24, wherein said system further comprises: 

a Quality of Service module ("QoS") configured to send said plurality of 
data packets to said coprocessor, wherein said coprocessor requests each of said data 
packets from said QoS; 

said QoS prioritizes said plurality of data packets according to a 
predetermined criteria before sending each of said data packets to said coprocessor. 

36. The system of Claim 24, wherein said system further comprises a 
decision module configured to determine if said buffer contains data to fill said 
downlink portion of said data frame by iteratively subtracting an amount of downlink 
bandwidth required by each of said incoming data packets, at each of said CPE's 
specific burst type, from a total amount of downlink bandwidth available, wherein a 
burst type is any combination of a modulation type and a FEC type. 

37. The system of Claim 24, wherein said first processor further comprises: 

an uplink bandwidth module configured to allocate available uplink 
bandwidth according to uplink bandwidth requests from said plurality of CPE's. 

38. A system for building a downlink portion of a FDD data frame having a 
predetermined period with a plurality of data packets, for use in a communication 
system having a base station and a plurality of Customer Premises Equipment's 
("CPE"), each of said plurality of CPE's being coupled to a plurality of end user 
connections, the system comprising: 




processor including a Media Access Controller ("MAC") 
configured to route said data packets to specified end user connections; 
a coprocessor including 

a buffer storage module configured to receive and sort said 
plurality of data packets in a buffer, 

a buffer update module configured to add control settings to said 
plurality of data packets in said buffer, 

an interface module configured to transmit said plurality of data 
packets in said buffer to a modem, wherein said transmission occurs during said 
predetermined period. 

39. The system of Claim 38, wherein said buffer storage module sorts said 
plurality of data packets in said buffer according to a burst type associated with each of 
said plurality of data packets, wherein a burst type is any combination of a modulation 
type and a FEC type. 

40. The system of Claim 38, wherein said predetermined period is five hundred 
microseconds. 

41. The system of Claim 38, wherein said predetermined period is one 
millisecond. 

42. The system of Claim 38, wherein said predetermined period is two 
milliseconds. 

43. The system of Claim 38, wherein said predetermined period is between 250 
microseconds and 20 milliseconds. 

44. The system of Claim 38, wherein said FDD frame further comprised an 
uplink portion and said interface module is configured to receive said uplink portion of 
said data frame from said modem, wherein said reception occurs during said 
predetermined period. 

45. The system of Claim 38, wherein said FDD frame further comprised an 
uplink portion and said interface module is configured to receive said uplink portion of 
said data frame from said modem, wherein said reception occurs during a second 
predetermined period, such that said predetermined period and said second 
predetermined period do not overlap. 
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46. The system of Claim 38, wherein said control settings may comprise a 
modulation type, a FEC type, an encryption ON/OFF flag, an encryption key, a key 
number, and modem control information specific to each CPE intended to receive a 
portion of said plurality of data packets in said downlink portion of said data frame. 

47. The system of Claim 38, wherein said system further comprises: 

a Quality of Service module ("QoS") configured to send said plurality of 
data packets to said coprocessor, wherein said coprocessor requests each of said data 
packets from said QoS; 

said QoS prioritizes said plurality of data packets according to a 
predetermined criteria before sending each of said data packets to said coprocessor. 

48. The system of Claim 38, wherein said system further comprises a 
decision module configured to determine if said buffer contains data to fill said 
downlink portion of said data frame by iteratively subtracting an amount of downlink 
bandwidth required by each of said incoming data packets, at each of said CPE's 
specific burst type, from a total amount of downlink bandwidth available, wherein a 
burst type is any combination of a modulation type and a FEC type. 

49. A method of building a data frame with a plurality of data packets, said data 
frame comprising a downlink portion and an uplink portion and having a predetermined 
period, for use in a communication system having a base station and a plurality of 
Customer Premises Equipment's ("CPE"), each of said plurality of CPE's being 
coupled to a plurality of end user connections, said base station including a MAC 
processor and a MAC coprocessor, said MAC coprocessor performing the steps of: 

(a) arranging incoming data packets according to a predetermined 

priority order, 

(b) receiving at said MAC coprocessor one of said plurality of data 
packets corresponding to one of said plurality of CPE's, according to said 
predetermined priority order, 

(c) sorting said plurality of data packets according to a burst type and 
storing said one of said plurality of data packets in a buffer, 
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(d) determining if } said predetermined ponod timeou t has occurred, 

. — . j^J-t - 

wherein in response to said determinatio^ matjcaiy predetermined period tim^u t-has 
occurred, skipping step (e) and going directly to step (f), 

(e) determining if said buffer contains enough of said plurality of 
data packets to fill said downlink portion of said data frame, wherein in response to said 
determination that said buffer does not contain enough of said plurality of data packets 
to fill said downlink portion of said data frame, repeating the process from step (a), 
otherwise continuing to step (f), 

(f) transferring contents of said buffer to a modem. 

50. The method of Claim 49, wherein said burst type is any combination of a 
modulation type and a FEC type. 

51. The method of Claim 49, wherein said predetermined period is five hundred 
microseconds. 

52. The method of Claim 49, wherein said predetermined period is one 
millisecond. 

53. The method of Claim 49, wherein said predetermined period is two 
milliseconds. 

54. The method of Claim 49, wherein said predetermined period is between 
250 microseconds and 20 milliseconds. 

55. The method of Claim 49, wherein said decision module determines if 
said buffer contains data to fill said downlink portion of said data frame by iteratively 
subtracting an amount of downlink bandwidth required by each of said incoming data 
packets, at each of said CPE's specific burst type, from a total amount of downlink 
bandwidth available. 

56. A system for transmitting at least a portion of an uplink data frame in a 
wireless communication system, said data frame having a plurality of data packets and 
having a predetermined period, said communication system having a base station and a 
plurality of Customer Premises Equipment's ("CPE"), each of said plurality of CPE's 
being coupled to a plurality of end user connections, the system comprising: 

a processor disposed in said base station including a Media Access 
Controller ("MAC") configured to allot a specific portion of an uplink portion of said 
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data frame to a specific CPE and to transmit an uplink map indicating said allotment to 
said specific CPE; 

an uplink data buffer configured to store uplink data received from said 
plurality of end user connections coupled to said specific CPE, 
5 a coprocessor disposed in said specific CPE configured to allocate said 

allotted portion of said data frame amongst a plurality of end user connections coupled 
to said specific CPE, said coprocessor comprising 

a look-up table configured to store priority parameters 
corresponding to each of said plurality of end user connections coupled to said 
10 specific CPE, 

a prioritizing module configured to prioritize said uplink data in 
said uplink data buffer according to said priority parameters corresponding to 
Q each of said plurality of end user connections connected to said specific CPE, 

IB a decision module configured to receive said uplink map from 

]5j /r 15 satdn&r^processor and determine, according to said received uplink map, when 

!^ a data burst should be sent to said base station, wherein said data burst contains 

h data pulled from said uplink data buffer in an order determined by said 

51 

p prioritizing module. 

57. The system of claim 56, wherein said coprocessor transmits a bandwidth 
20 request to said processor. 

58. The system of claim 57, wherein said bandwidth request is transmitted to 
said processor in the event said allotted portion of said uplink map is not long enough to 
transmit all of said uplink data currently stored in said uplink data buffer. 

59. The system of claim 57, wherein said bandwidth request is transmitted 
25 during a bandwidth request contention slot portion of said uplink portion of said data 

frame. 

60. The system of claim 57, wherein said bandwidth request is transmitted 
during a portion of said uplink portion of said data frame allotted to a second specific 
CPE. 

30 61 . The system of claim 56, wherein said data burst comprises a poll-me bit; 
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said poll-me bit is set such that said MAC will poll said specific CPE 
with a bandwidth inquiry. 

62. The system of claim 56, wherein said coprocessor may perform any 
combination of packing, payload header compression, and fragmentation on said data 
burst. 

63. The system of claim 56, wherein said decision module determines how 
much data will fit in said data burst such that said data burst may be transmitted during 
said allotted portion of said uplink data frame; 

said determination is made with respect to a modulation type of said 

specific CPE. 

64. A method of transmitting at least a portion of an uplink data frame in a 
wireless communication system, said data frame having a plurality of data packets and 
having a predetermined period, said communication system having a base station and a 
plurality of Customer Premises Equipment's ("CPE"), each of said plurality of CPE's 
being coupled to a plurality of end user connections, the method comprising: 

transmitting from said base station to a specific CPE an uplink map 
indicating an allotted portion of said uplink data frame allotted to said specific CPE; 
said CPE performing the steps of 

storing a plurality of uplink data received from said plurality of 
end user connections coupled to said specific CPE in an uplink data buffer, 

receiving said uplink map from said base station, 

prioritizing said uplink data in said uplink data buffer according 
to a priority parameter corresponding to each of said plurality of end user connections, 

allocating said allotted portion of said data frame amongst a 
plurality of end user connections coupled to said specific CPE, 

determining a transmit time, according to said received uplink 
map, when a data burst should be sent to said base station, wherein said data burst 
contains data pulled from said uplink data buffer in an order determined by said 
prioritizing, 

transmitting said data burst at said transmit time. 
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65. The method of claim 64 further comprising transmitting a bandwidth 
request to said base station. 

66. The method of claim 65, wherein said bandwidth request is transmitted 
in the event said allotted portion of said uplink map is not long enough to transmit all of 
said uplink data currently stored in said uplink data buffer. 

67. The method of claim 65, wherein said bandwidth request is transmitted 
during a bandwidth request contention slot portion of said uplink portion of said data 
frame. 

68. The method of claim 65, wherein said bandwidth request is transmitted 
during a portion of said uplink portion of said data frame allotted to a second specific 
CPE. 

69. The method of claim 64, wherein said data burst comprises a poll-me bit; 
said poll-me bit is set, such that said MAC will poll said specific CPE 

with a bandwidth inquiry. 

70. The method of claim 64, wherein said coprocessor may perform any 
combination of packing, payload header compression, and fragmentation on said data 
burst. 

71 . The method of claim 64, further comprising the step of 

determining how much data will fit in said data burst such that said data 
burst may be transmitted during said allotted portion of said uplink data frame; 

said determination is made with respect to a modulation type of said 

specific CPE. 
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